





# Computer Organization & Design 实验与课程设计

### 实验六

#### CPU设计-控制器

施青松

Asso. Prof. Shi Qingsong
College of Computer Science and Technology, Zhejiang University
zjsqs@zju.edu.cn

#### **Course Outline**



### 实验目的与实验环境

实验任务

实验原理

实验操作与实现

淅沙人学系统结构与系统软件实验室

### 实验目的



- 1. 运用寄存器传输控制技术
- 2. 掌握CPU的核心: 指令执行过程与控制流关系
- 3. 设计控制器
- 4. 学习测试方案的设计
- 5. 学习测试程序的设计

### 实验环境



#### □实验设备

- 1. 计算机(Intel Core i5以上,4GB内存以上)系统
- 2. Spartan-3 Starter Kit Board/Sword开发板
- 3. Xilinx ISE14.4及以上开发工具

#### □材料

无

### **Course Outline**



实验目的与实验环境

实验任务

实验原理

实验操作与实现

洲沙太学系统结构与系统软件实验室

### 实验任务



#### 1. 设计9+条指令的控制器

- 用硬件描述语言设计实现控制器 □根据Exp05数据通路及指令编码完成控制信号真值表
- 替换Exp05的控制器核
- 此实验在Exp05的基础上完成

#### 2. 设计控制器测试方案:

- OP译码测试: R-格式、访存指令、分支指令、转移指令
- 运算控制测试: Function译码测试

#### 3. 设计控制器测试程序

#### **Course Outline**



实验目的与实验环境

实验任务

实验原理

实验操作与实现

浙江大学系统结构与系统软件实验室

#### **CPU organization**



#### **□** Digital circuit

General circuits that controls logical event with logical gates Hardware



#### **□** Computer organization

Special circuits that processes logical action with instructions
 -Software



### 控制对象:数据通路结构





### 控制信号定义



#### □通路与操作控制

| <i>t</i> >. |             | A AMANAN    | makata satut |                     |
|-------------|-------------|-------------|--------------|---------------------|
| 信号          | 源数目         | 功能定义        | 赋值0时动作       | 赋值1时动作              |
| ALUSrc_B    | 2           | ALU端口B输入选择  | 选择寄存器B数据     | 选择32位立即数<br>(符号扩展后) |
| RegDst      | 2           | 寄存器写地址选择    | 选择指令rt域      | 选择指令rs域             |
| MemtoReg    | 2           | 寄存器写入数据选择   | 选择存储器数据      | 选择ALU输出             |
| Branch      | 2           | Beq指令目标地址选择 | 选择PC+4地址     | 选择转移地址<br>(Zero=1)  |
| Jump        | 2           | J指令目标地址选择   | 选择J目标地址      | 由Branch决定输<br>出     |
| RegWrite    | 1           | 寄存器写控制      | 禁止寄存器写       | 使能寄存器写              |
| MemWrite    | ı           | 存储器写控制      | 禁止存储器写       | 使能存储器写              |
| MemRead     | -           | 存储器读控制      | 禁止存储器读       | 使能存储器读              |
| ALU_Control | 000-<br>111 | 3位ALU操作控制   | 参考表Exp04     | Exp04               |

浙江大学 计算机学院 系统结构与系统软件实验室

### 主控制器信号真值表



□分析填写控制器输出信号真值表

| OP      | Reg<br>Dst | ALU<br>Src | Mem<br>toReg | Reg<br>Write | Mem<br>Read | Mem<br>Write | Branch | Jump | ALU<br>op1 | ALU<br>op0 |
|---------|------------|------------|--------------|--------------|-------------|--------------|--------|------|------------|------------|
| R-格式    |            |            |              |              |             |              |        |      |            |            |
| 000000  |            |            |              |              |             |              |        |      |            |            |
| I-格式LW  |            |            |              |              |             |              |        |      |            |            |
| ???     |            |            |              |              |             |              |        |      |            |            |
| I-格式SW  |            |            |              |              |             |              |        |      |            |            |
| ???     |            |            |              |              |             |              |        |      |            |            |
| I-格式beq |            |            |              |              |             |              |        |      |            |            |
| ???     |            |            |              |              |             |              |        |      |            |            |
| J-格式    |            |            |              |              |             |              |        |      |            |            |
| ???     |            |            |              |              |             |              |        |      |            |            |
|         |            |            |              |              |             |              |        |      |            |            |
|         |            |            |              |              |             |              |        |      |            |            |
|         |            |            |              |              |             |              |        |      |            |            |
|         |            |            |              |              |             |              |        |      |            |            |

### ALU操作译码

# Second level

#### □参考实验四

| Instruction opcode | ALUop | Instruction operation | Funct field | Desired<br>ALU action | ALU_Control |
|--------------------|-------|-----------------------|-------------|-----------------------|-------------|
| LW                 | 00    | Load word             | XXXXXX      | Load word             | 010         |
| SW                 | 00    | Store word            | xxxxx       | xxxxxx Store word     |             |
| Beq                | 01    | branch equal          | XXXXX       | branch equal          | 110         |
| R-type             | 10    | add                   | 10 0000     | add                   | 010         |
| R-type             | 10    | subtract              | 10 0010     | subtract              | 110         |
| R-type             | 10    | AND                   | 10 0100     | AND                   | 000         |
| R-type             | 10    | OR                    | 10 0101     | OR                    | 001         |
| R-type             | 10    | Set on less than      | 10 1010     | Set on less than      | 111         |
| R-type             | 10    | NOR                   | 100111      | NOR                   | 100         |



### ALU操作译码化简



#### □ 对Funct变量化简

- ALUop 单独考虑
  - □化简后合并

$$ALU\_Control_2 = \begin{cases} ALU\_control_2 = & ALU\_control_1 = \\ ALU\_Control_0 = & ALU\_control_0 = \\ ALU\_contro$$

| F.F.     | Fo | ? |   |    |   |
|----------|----|---|---|----|---|
| $F_3F_2$ | 0  | Х | X | 1  | 1 |
|          | 0  | 0 | 1 | X  | / |
|          | X  | X | X | X  |   |
|          | X  | X | X | 1/ |   |





反函数简单

浙江大学

计算机学院 系统结构与系统软件实验室

### CPU部件之控制器接口: SCPU\_ctrl



#### □ SCPU\_ctrl

- CPU主要部件之一
- 寄存器传输控制者: 编码转换成命令

#### □基本功能

- ■微操作控制
- ■数据传输通道控制
- 时序控制: 单周期时序在那里?

#### □接口要求-SCPU\_ctrl

- ■控制器接口信号如右图
- 模块符号文档: SCPU\_ctrl.sym





计算机学院 系统结构与系统软件实验室

### 数据通路接口信号标准- SCPU\_ctrl.v



```
module
         SCPU ctrl(input[5:0]OPcode, //OPcode
                    input[5:0]Fun, //Function
                    input MIO_ready, //CPU Wait
                    output reg RegDst,
                    output reg ALUSrc B,
                    output reg MemtoReg,
                    output reg Jump,
                    output reg Branch,
                    output reg RegWrite,
                    output reg mem_w,
                    output reg [2:0]ALU_Control,
                    output reg CPU_MIO
                    );
```

endmodule

### **Course Outline**



实验目的与实验环境

实验任务

实验原理

实验操作与实现

浙江大学系统结构与系统软件实验室



## CPU之控制器设计

-控制实验五设计的数据通路

### 设计工程: OExp06-OwnSCPU



#### ◎设计CPU之控制器

- 全根据理论课分析讨论设计实验五数据通路的的控制器
- € 原理图或HDL描述均可
  - ⊙但必须用函数表达式结构描述
- € 仿真测试控制器模块

#### ◎集成替换验证通过的数据通路模块

- € 替换实验五(Exp05)中的SCPU\_ctrl.ngc核
- € 顶层模块延用Exp05
  - ⊙ 模块名: Top\_OExp06\_OwnSCPU.sch

#### ◎测试控制器模块

- E 设计测试程序(MIPS汇编)测试:
- & OP译码测试:
  - ⊙R-格式、访存指令、分支指令,转移指令
- 全运算控制测试: Function译码测试: 人名英格特罗尔德特 医二甲基甲基

### 设计要点



#### □设计主控制器模块

- ■写出控制器的函数表达式
- 结构描述实现电路

#### □设计ALU操作译码

- ■写出ALU操作译码函数表达式
- 结构描述实现电路
- ■使用DEMO作功能初步调试
  - □ ALU必须运算包含"nor"操作
  - □否则需要修改或重新设计调试程序

#### □仿真二个控制器电路模块

■ 可以单独或合并仿真,但最后要合并为一个控制模块



### 指令译码-主控制器逻辑电路





浙江大学 计算机学院 系统结构与系统软件实验室

### 主控制器HDL描述结构



#### □指令译码器参考描述

```
`define CPU_ctrl_signals
{RegDst,ALUSrc_B,MemtoReg,RegWrite,MemRead,MemWrite,Branch,Jump,ALUop}
         assign mem_w = MemWrite&&(~MemRead);
         always @* begin
                  case(OPcode)
                  6'b000000: begin CPU_ctrl_signals = ?; end
                                                               //ALU
                  6'b100011: begin CPU_ctrl_signals = ?; end
                                                               //load
                  6'b101011: begin CPU_ctrl_signals = ?; end
                                                               //store
                  6'b000100: begin CPU_ctrl_signals = ?; end
                                                               //beq
                  6'b000010: begin CPU_ctrl_signals = ?; end
                                                               //jump
                  6'h24:
                                                               //slti, 增加ALUop编码
                            begin CPU_ctrl_signals = ?; end
                  default:
                            begin CPU_ctrl_signals = ?; end
                  endcase
        end
```

### 控制器仿真激励代码参考



```
initial begin
        // Initialize Inputs
        OPcode = 0:
        Fun = 0:
        MIO_ready = 0;
        #40:
        // Wait 40 ns for global reset to finish。以上是测试模板代码。
        // Add stimulus here
        //检查输出信号和关键信号输出是否满足真值表
        OPcode = 0; //ALU指令,检查ALUop=2'b10; RegDst=1; RegWrite=1
        Fun = 6'b100000; //add, 检查ALU_Control=3'b010
        #20:
        Fun = 6'b100010: //sub. 检查ALU Control=3'b110
        #20:
        Fun = 6'b100100; //and,检查ALU Control=3'b000
        #20:
        Fun = 6'b100101; //or, 检查ALU Control=3'b001
        #20:
        Fun = 6'b101010; //slt, 检查ALU Control=3'b111
        #20:
        Fun = 6'b100111; //nor, 检查ALU Control=3'b100
        #20:
```

### 控制器仿真激励代码参考



```
#20:
Fun = 6'b000010; //srl, 检查ALU Control=3'b101
#20:
Fun = 6'b010110; //xor, 检查ALU Control=3'b011
#20:
Fun = 6'b1111111: //间隔
#1:
OPcode = 6'b100011; //load指令,检查ALUop=2'b00, RegDst=0,
#20:
                 //ALUSrc\ B=1, MemtoReg=1, RegWrite=1
OPcode = 6'b1010111;
#20; //store指令,检查ALUop=2'b00, mem_w=1, ALUSrc_B=1
OPcode = 6'b000100; //beq指令,检查ALUop=2'b01, Branch=1
#20:
OPcode = 6'b000010; //jump指令,检查Jump=1
#20:
OPcode = 6'h24; //slti指令,检查ALUop=2'b11, RegDst=0,
#20:
             //ALUSrc_B=1, RegWrite=1
                        //间隔
OPcode = 6'h3f;
                        //间隔
Fun = 6'b0000000:
```

end

### 控制器模块时序仿真结果





浙江大学

计算机学院 系统结构与系统软件实验室

### ALU操作译码器逻辑电路





### ALU操作译码器HDL描述结构



#### □ALU控制器参考描述

```
always @* begin
  case(ALUop)
  2'b00: ALU Control = ?;
                                             //add计算地址
                                             //sub比较条件
  2'b01: ALU Control = ?;
  2'b10:
     case(Fun)
         6'b100000: ALU Control = 3'b010;
                                             //add
         6'b100010: ALU Control = ?;
                                             //sub
         6'b100100: ALU Control = ?;
                                             //and
         6'b100101: ALU Control = ?;
                                             //or
         6'b101010: ALU Control = ?;
                                             //slt
         6'b100111: ALU Control = ?;
                                            //nor:~(A | B)
         6'b000010: ALU Control = ?;
                                             //srl
         6'b010110: ALU_Control = ?;
                                             //xor
         default: ALU_Control=3'bx;
         endcase
  2'b11: ALU Control = ?;
                                             //slti
  endcase
```

浙江大学

计算机学院 系统结构与系统软件实验室

### 控制器集成替换



#### □集成替换

- 仿真正确后替换Exp05的控制器IP核
- □移除工程中的控制器核
  - Exp05工程中移控制器核关联
  - 删除工程中控制器核文件
    - □ SCPU\_ctrl.ngc文件
    - 在Project菜单中运行: Cleanup Project Files ...
  - 建议用Exp05资源重建工程
    - □ 除SCPU\_ctrl.ngc核

Top\_OExp05\_DataPath (Top\_OExp05\_DataPath.sch) U61 - Seg7 Dev (Seg7 Dev.ngc) U61 - Seg7\_Dev (Seg7\_Dev\_IO.v) U5 - Multi\_8CH32 (Multi\_8CH32.ngc) U5 - Multi 8CH32 (Multi 8CH32 IO.v) U8 - clk div (clk div.v) U7 - SPIO (SPIO.ngc) U7 - SPIO (SPIO\_IO.v) U6 - SSeg7\_Dev (SSeg7\_Dev.ngc) U6 - SSeg7 Dev (SSeg7 Dev IO.v) U9 - SAnti jitter (SAnti jitter.ngc) U9 - SAnti\_jitter (SAnti\_jitter\_IO.v) M4 - SEnter\_2\_32 (SEnter\_2\_32.ngc) M4 - SEnter 2 32 (SEnter 2 32 IO.v) U71 - PIO (PIO.ngc) U71 - PIO (PIO\_IO.v) U2 - ROM D (ROM D.xco) U3 - RAM B (RAM B.xco) U4 - MIO BUS (MIO BUS.ngc) U4 - MIO BUS (MIO BUS IO.v) U10 - Counter x (Counter x.ngc) U10 - Counter\_x (Counter\_3\_IO.v) U1 - SCPU (SCPU.sch)

Exp05需要清理的核

DataPath - Data\_path (Data\_path.sch)
 Controler - SCPU\_ctrl (SCPU\_ctrl.ngc)

Ontroler - SCPU\_ctrl (SCPU\_ctrl.v)

Org-Sword.ucf



计算机学院 系统结构与系统软件实验室



□ 集成替换SCPU\_ctrl核后的 模块层次结构

> Exp06完成数据通路替换 后的模块调用关系

替换后的控制器模块

Top\_OExp06\_OwnSCPU (Top\_OExp06\_OwnSCPU.sch)

10 U61 - Seg7\_Dev (Seg7\_Dev.ngc)

10 U61 - Seg7\_Dev (Seg7\_Dev\_IO.v)

U5 - Multi\_8CH32 (Multi\_8CH32.ngc)

U5 - Multi\_8CH32 (Multi\_8CH32\_IO.v)

· V U8 - clk\_div (clk\_div.v)

U7 - SPIO (SPIO.ngc)

· ☑ U7 - SPIO (SPIO\_IO,v)

G U6 - SSeg7\_Dev (SSeg7\_Dev.ngc)

U6 - SSeg7\_Dev (SSeg7\_Dev\_IO.v)

U9 - SAnti\_jitter (SAnti\_jitter.ngc)

☑ U9 - SAnti\_jitter (SAnti\_jitter\_IO.v)

M4 - SEnter\_2\_32 (SEnter\_2\_32.ngc)

M4 - SEnter 2 32 (SEnter 2 32 IO.v)

U71 - PIO (PIO.ngc)

V U71 - PIO (PIO\_IO.v)

U2 - ROM\_D (ROM\_D.xco)

V3 - RAM\_B (RAM\_B.xco)

U4 - MIO\_BUS (MIO\_BUS.ngc)

U4 - MIO\_BUS (MIO\_BUS\_IO.v)

U10 - Counter\_x (Counter\_x.ngc)

U10 - Counter\_x (Counter\_3\_IO.v)

U1 - SCPU (SCPU.sch)

🗓 🖸 DataPath - Data\_path (Data\_path.sch)

Controler - SCPU ctrl (SCPU ctrl.sch)

🛂 Org-Sword.ucf



### 物理验证



- □ 使用DEMO程序目测控制器功能(同实验五)
  - DEMO接口功能
    - □ SW[7:5]=000, SW[2]=0(全速运行)
      - SW[4:3]=00, SW[0]=0, 点阵显示程序: 跑马灯
      - SW[4:3]=00, SW[0]=0, 点阵显示程序: 矩形变幻
      - SW[4:3]=01, SW[0]=1, 内存数据显示程序: 0~F
      - SW[4:3]=10, SW[0]=1, 当前寄存器R9+1显示

#### □用汇编语言设计测试程序

- ■测试ALU指令(R-格式译码、Function译码)
- 测试LW/SW指令(I-格式译码)
- 测试分支指令(I-格式译码)
- 测试转移指令(J-格式译码)

### 物理验证-DEMO接口功能





SW[7:5]=显示通道选择

SW[7:5]=000: CPU程序运行输出

ISW[7:5]=001:测试PC字地址

SW[7:5]=010:测试指令字

SW[7:5]=011: 测试计数器

SW[7:5]=100: 测试RAM地址

SW[7:5]=101: 测试CPU数据输出

**■SW[7:5]=110:**测试CPU数据输入

SW[0]=文本图形选择

SW[1]=高低16位选择

没有使用

SW[2]=CPU单步时钟选择

DEMO功能,测试程序可以替换成自己的功能

SW[4:3]=00,点阵显示程序: 跑马灯

┗SW[4:3]=00,点阵显示程序: 矩形变幻

SW[4:3]=01,内存数据显示程序:0~F

SW[4:3]=10, 当前寄存器+1显示



计算机学院



### 测试程序参考: ALU指令



- □设计ALU指令测试程序替换DEMO程序
  - ALU、Regs测试参考设计,测试结果通过CPU输出信号单步观察
  - SW[7:5]=100, Addr\_out = ALU输出
  - SW[7:5]=101, Data\_out= 寄存器B输出

```
#baseAddr 0000
loop:
      nor r1,r0,r0;
                          //r1=FFFFFFF
                          //r2=00000001
        slt r2,r0,r1;
        add r3,r2,r2;
                          //r3=00000002
                          //r4=00000004
        add r4,r3,r3;
        add r5,r4,r2;
                          //r5=00000005
        add r6,r5,r5;
                          //r6=0000000A
        nor r7,r5,r5;
                          //r7=FFFFFFA
        sub r8,r7,r5;
                          //r8=FFFFFF5
        and r9,r8,r5;
                          //r9=00000005
        and r10,r8,r6;
                          //r10=00000000
        or r11,r5,r6;
                         //r11=0000000F
        or r12,r11,r7;
                          //r12=0000000A
        slt r13,r5,r7;
                          //r13=00000000
j loop;
```

### 测试程序参考: LW/SW



- □ 设计LW/SW程序替换DEMO程序
  - 参考Lab5通道测试设计。测试结果通过CPU输出信号单步观察
  - 存储器地址通过Addr\_out通道4观察: 14+\$zero

```
#baseAddr 0000
                          //通道结果由后一条指令读操作数观察
start:
                          //取测试常数5555555。存储器读通道
      lw r5, 14($zero);
start A:
                          //r1: 寄存器写通道。R5:寄存器读通道A输出
      add r1, r5, $zero;
                          //r1: 寄存器读通道B输出。R2:ALU输出通道
      nor r2, $zero, r1;
      lw r5, 48($zero); //取测试常数AAAAAAA。立即数通道:00000048
                          //循环测试
      beq r2, r5 test_sw;
                          //循环测试。立即数通道: 0000014
         start:
                          //增加写SW测试,如14和48单元交换
test_sw:
                          //循环测试。立即数通道: 0000014
      i start:
```

- □测试的完备性
  - 上述测试正确仅表明地址计算、存储单元和总线传输部分正确
  - 要测试其完全正确,必须遍历所有可能的情况

浙江大学 计算机学院 系统结构与系统软件实验室

### 动态LW/SW测试



#### □利用七段显示设备可以设计动态测试程序

- 7段码显示器的地址是E000000/FFFFFE0
- LED显示地址是F000000/FFFFFF00
- SW指令输出测试结果: sw
- 请设计存储器模块测试程序
  - □测试结果在7段显示器上指示

#### □ RAM初始化数据同Lab5

```
F0000000, 000002AB, 80000000, 0000003F,
                                        00000001, FFF70000,
0000FFFF,
         80000000, 000000000,
                              11111111, 22222222, 33333333,
4444444, 55555555, 66666666, 77777777,
                                        88888888, 99999999,
aaaaaaaa, bbbbbbbb, ccccccc, dddddddd,
                                        eeeeeee, FFFFFFF,
557EF7E0,
         D7BDFBD9, D7DBFDB9, DFCFFCFB,
                                                  F7F3DFFF,
                                        DFCFBFFF,
FFFFDF3D,
         FFFF9DB9, FFFFBCFB, DFCFFCFB,
                                        DFCFBFFF,
                                                  D7DB9FFF,
D7DBFDB9,
         D7BDFBD9, FFFF07E0, 007E0FFF, 03bdf020,
                                                  03def820.
08002300;
```



计算机学院 系统结构与系统软件实验室

### 设计测试记录表格



- □ALU指令测试结果记录
  - ■自行设计记录表格
- □ LW/SW指令测试结果记录
  - ■自行设计记录表格
- □动态存储模块测试记录
  - ■自行设计记录表格

### 思考题



- □ 单周期控制器时序体现在那里?
- □设计bne指令需要增加控制信号吗?
- □扩展下列指令,控制器将作如何修改:

R-Type:

srl\*, jr, jalr, eret\*;

I-Type:

addi, andi, ori, xori, lui, bne, slti

J-Type:

Jal;

- 此时用二级译码有优势吗?
- □ 动态存储模块测试七段显示会出现什么问题?



## **END**